package com.personnel.mapper;

import com.personnel.pojo.ExtraWork;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;

import java.util.List;

/**
 * (ExtraWork)表数据库访问层
 *
 * @author yuepeng
 * @since 2022-03-04 10:28:31
 * @version 1.0
 */
@Mapper
public interface ExtraWorkMapper {

    /**
     * 查询所有数据
     * @return  返回所有数据
     */
    List<ExtraWork> selectAll();

    /**
     * 通过ID查询单条数据
     *
     * @param extraWorkId 主键
     * @return 实例对象
     */
    ExtraWork selectById(@Param("id") Integer extraWorkId);

    /**
     * 根据模糊条件查询总个数
     *
     * @return 返回查询到的总个数
     */
    int selectForCount(@Param("staffName") String staffName, @Param("status")Integer status);

    int selectCountForTime(@Param("staffName") String staffName);

    /**
     * 通过实体作为筛选条件查询
     * 
     * @param index 查询起始位置
     * @param staffName  查询条件
     * @return 对象列表
     */
    List<ExtraWork> selectForPage(@Param("index") int index, @Param("limit") int limit, @Param("staffName")String staffName, @Param("status")Integer status);

    /**
     * 新增数据
     *
     * @param extraWork 实例对象
     */
    void insert(ExtraWork extraWork);

    /**
     * 修改数据
     *
     * @param extraWork 实例对象
     * @return 影响行数
     */
    int updateById(ExtraWork extraWork);

    /**
     * 通过主键删除数据
     *
     * @param extraWorkId 主键
     * @return 影响行数
     */
    int deleteById(@Param("extraWorkId") String extraWorkId);

}